<template>
<div>
  <div class="card-Box">
      <el-form :inline="true" :model="dataForm"  @keyup.enter.native="getDataList()">
        <el-form-item label="查找权限">
          <el-select v-model="dataForm.roleId" clearable placeholder="请选择" >
            <el-option v-for="item in roleList"  :key="item.id" :label="item.name" :value="item.id"></el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="用户名">
          <el-input v-model="dataForm.username" placeholder="请输入用户名" clearable></el-input>
        </el-form-item>
        <!-- <el-form-item> -->
          <el-button @click="getDataList()" type="primary" class="search">搜索</el-button>
        <!-- </el-form-item> -->
        <!-- <el-form-item> -->
          <el-button type="info" class="reset" @click="resetForm()">重置</el-button>
        <!-- </el-form-item> -->
      </el-form>
      </div>
      <div class="aui-card--fill">
        <!-- <el-form class="box">
          <div class="userListText">用户列表</div>
         <el-form-item>
          <el-button class="newAdd" v-if="$hasPermission('sys:user:save')" type="primary" @click="addOrUpdateHandle()">新增</el-button>
        </el-form-item>
      </el-form> -->
      <div class="userBox">
        <div class="userListText">用户列表</div>
        <el-button class="newAdd" v-if="$hasPermission('sys:user:save')" type="primary" @click="addOrUpdateHandle()">新增</el-button>
      </div>
      <el-table
        v-loading="dataListLoading"
        :data="dataList"
        border
        @selection-change="dataListSelectionChangeHandle"
        @sort-change="dataListSortChangeHandle"
        style="width: 100%;"
        class="formBox">
        <el-table-column label="序号" header-align="center" align="center" type="index" width="50"></el-table-column>
        <el-table-column prop="username" label="用户名" header-align="center" align="center"></el-table-column>
        <el-table-column prop="realPassword" label="密码" header-align="center" align="center"></el-table-column>
        <el-table-column prop="roleName" label="权限组" header-align="center" align="center"></el-table-column>
        <el-table-column prop="status" :label="$t('user.status')" header-align="center" align="center">
          <template slot-scope="scope">
            <!-- <el-tag v-if="scope.row.status === 0" size="small" type="danger">{{ $t('user.status0') }}</el-tag>
            <el-tag v-else size="small" type="success">{{ $t('user.status1') }}</el-tag> -->
            <el-tag v-if="scope.row.status === 1" size="small" type="success">正常</el-tag>
            <el-tag v-if="scope.row.status === 0" size="small" type="danger">停用</el-tag>
          </template>
        </el-table-column>
        <el-table-column prop="remark" label="备注" header-align="center" align="center" width="300">
          <!-- <template slot-scope="scope">
            {{ $getDictLabel("gender", scope.row.gender) }}
          </template> -->
        </el-table-column>
        <!-- <el-table-column prop="createDate" :label="$t('user.createDate')" sortable="custom" header-align="center" align="center" width="180"></el-table-column> -->
        <el-table-column :label="$t('handle')" fixed="right" header-align="center" align="center" width="200">
          <template slot-scope="scope">
            <el-button v-if="$hasPermission('sys:user:update')" type="primary" round size="mini" @click="addOrUpdateHandle(scope.row.id)">{{ $t('update') }}</el-button>
            <el-button v-if="$hasPermission('sys:user:delete')" type="danger" round size="mini" @click="deleteHandle(scope.row.id)">{{ $t('delete') }}</el-button>
          </template>
        </el-table-column>
      </el-table>
      <el-pagination
        background
        :current-page="page"
        :page-sizes="[10, 20, 50, 100]"
        :page-size="limit"
        :total="total"
        layout="total, sizes, prev, pager, next, jumper"
        @size-change="pageSizeChangeHandle"
        @current-change="pageCurrentChangeHandle">
      </el-pagination>
      <!-- 弹窗, 新增 / 修改 -->
      <add-or-update v-if="addOrUpdateVisible" ref="addOrUpdate" @refreshDataList="getDataList"></add-or-update>
  </div>
  </div>
</template>

<script>
import mixinViewModule from '@/mixins/view-module'
import AddOrUpdate from './user-add-or-update'
export default {
  mixins: [mixinViewModule],
  data () {
    return {
      mixinViewModuleOptions: {
        getDataListURL: '/sys/user/page',
        getDataListIsPage: true,
        deleteURL: '/sys/user',
        deleteIsBatch: true,
        exportURL: '/sys/user/export'
      },
      dataForm: {
        username: '',
        deptId: '',
      },
      roleList:[]
    }
  },
  components: {
    AddOrUpdate
  },
  activated() {
    this.getRoleList()
  },
  methods: {
      getRoleList () {
        this.$http.get('/sys/role/list').then(( res ) => {
        this.roleList = res.data.data
      }).catch(() => {})
    },
    resetForm(){
      this.dataForm.username = '',
      this.dataForm.roleId = '',
      this.$http.get('/sys/user/page').then(res => {
        this.dataList = res.data.data.list
      })
    }
  },
}
</script>
<style scoped>
  .card-Box {
  	width: 100%;
  	height: 7.6vh;
  	line-height: 7.6vh;
  	padding: 0 1.8vw;
  	background-color: #fff;
  	border-radius: 10px;
  	display: flex;
  	align-items: center;
  	margin-bottom: 10px;
  }
  .card-Box>>>.el-form--inline .el-form-item__content,.el-form--inline .el-form-item{
  	vertical-align: middle!important;
  }
  .card-Box>>> .el-form-item{
  	margin-bottom: 0;
  }
  .aui-card--fill{
    width: 100%;
    /* height: 750px; */
    padding: 1.8vh 2vw 1.8vh 2vw;
    background-color: #fff;
    border-radius: 10px;
  }
  .selectRegion{
    width: 100%;
    height: 10vh;
  }
  /* .mod-sys__user{
    position: relative;
  } */
  .search{
   /* margin-left: 6.25vw;
    width: 5.9vw;
    height: 3.8vh; */
  }
  .reset{
   /* width: 5.9vw;
    height: 3.8vh;
    margin-left: 1.875vw; */
    background-color: rgba(180, 196, 209, 1);
    border: 1px solid rgba(180, 196, 209, 1);
  }
  .userBox{
    display: flex;
    position: relative;
    width: 100%;
    height: 3vh;
    margin-bottom: 1.9vh;
  }
  .userListText{
    /* width: 5vw; */
    height: 3vh;
    line-height: 3vh;
    font-size: 16px;
  }
  .newAdd{
    position: absolute;
    right: 0;
    width: 5.9vw;
    height: 3vh;
    padding: 0;
  }
  .aui-card--fill>>>.el-table__fixed-right{
	height: 100%!important;  
  }
</style>
